Skip to content

响应式网站开发

响应式网站指一个网站要适配PC端、Pad端、Mobile端。

1、CSS媒体查询

通过CSS3的媒体查询,根据不同的屏幕尺寸区间设置不同的样式效果,和不同尺寸的图片,来保证页面图片显示不失真,布局元素错乱。

参考示例:

2、栅格布局

栅格布局是一种网格化的页面布局方式,它由行和列组成。

参考示例:

3、弹性布局(flex/grid)

Flexbox是一种基于弹性盒子模型的布局技术。

  • 使用 Flexbox 布局可以让元素自动适应不同屏幕尺寸
  • 元素可以自动换行、伸缩,减少媒体查询的使用
  • 特别适合一维布局(行或列)

4、隐藏/显示

5、调整元素顺序

6、CSS变量(自定义属性)配合媒体查询

参考示例:暴雪官网

:root {
  --main-font-size: 16px;
}

@media (max-width: 768px) {
  :root {
    --main-font-size: 14px;
  }
}

.text {
  font-size: var(--main-font-size);
}
:root {
  --main-font-size: 16px;
}

@media (max-width: 768px) {
  :root {
    --main-font-size: 14px;
  }
}

.text {
  font-size: var(--main-font-size);
}

7、移动优先设计(Mobile First)

scss
// 网站的响应式设计:移动优先设计(Mobil e First)
// 移动端默认样式
.container {
  width: 100%;
}

// 平板(屏幕宽度不小于768px时)
@media (min-width: 768px) {
  .container {
    width: 750px;
  }
}

// 桌面(屏幕宽度不小于1024时)
@media (min-width: 1024px) {
  .container {
    width: 960px;
  }
}
// 网站的响应式设计:移动优先设计(Mobil e First)
// 移动端默认样式
.container {
  width: 100%;
}

// 平板(屏幕宽度不小于768px时)
@media (min-width: 768px) {
  .container {
    width: 750px;
  }
}

// 桌面(屏幕宽度不小于1024时)
@media (min-width: 1024px) {
  .container {
    width: 960px;
  }
}

响应式网站开发建议